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Description 

The present invention relates to a method to protect content within protected 
data areas on a target optical record carrier against unauthorized reading 
5 and /or copying with a computer, and an optical record carrier. 

Optical storage carriers with information stored on one or both sides have come 
to be used for a variety of purposes, most notably in the music, games, video, 
and computer industry. Digital information is stored on the optical storage 
10 media in the form of pits arranged along circular, concentric tracks on one or on 
both sides of the disc. The track is typically read from the inside out, but may 
also be read form outside in, as it is already used for some optical storage 
media. 



15 The data itself on the track is subdivided into frames, each equal in length, 
containing equal amounts of information. Each frame has a dedicated layout 
depending on the type of optical storage media (CD, DVD). Such a frame always 
contains the user data symbols itself but may also contain data for 
synchronization, merging data between data symbols and error correction. 

20 

The signal on an optical storage medium itself is asynchronous, which means 
that in the decoding process synchronization, timing information, parity data or 
other data has to be spied out from the signal and the signal has to fulfil certain 
requirements so that it is accessible by a reading device. 

25 

Due to the nature of such storage media copies can be made easily. To cope with 
this situation, there exist various copy protection schemes according to which 
the data relating to the information itself and/ or the other data on the storage 
medium providing access information or relating to the synchronization gets 
30 altered to prohibit digital copying while accomplishing accessibility by playback 
devices. 

Generally, these copy protection schemes prevent a playback of the information 
content on computer drives by confusing these drives at least in respect to the 
35 access of the information content. To secure an access to the content, a quality 
reduced version of the content, which is stored a copy protected" in a first 
session of the optical record carrier, might be provided- in-a computer accessible 
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manner in a second session of the optical record carrier. Alternatively the 
second session might comprise a link to a content server to provide a computer 
access. Such a content server might also comprise added value, e.g. music clips 
or bonus material related to the information content on the optical record 
earner. The access to the content stored in the second session and/or to the 
content server might be provided through an executable file that automatically 
starts after the copy protected optical record carrier is inserted into the 
computer drive. 

In view of the above, it is the object underlying the present invention to provide 
an improved system to protect content within protected data areas on a target 
optical record carrier against unauthorized reading and/or copying with a 
computer. 

According to the present invention, this object is solved by a method to protect 
content within protected data areas on a target optical record carrier against 
unauthorized reading and/or copying with a computer as defined in independent 
claim 1. Preferred embodiments of the method according to the present invention 
are defined in the respective dependent claims. A computer program product 
according to the present invention is defined in claim 12, a computer readable 
storage means according to the present invention is defined in claim 13 and an 
optical record carrier according to the present invention is defined in claim 14. 

The method to protect content within protected data areas on a target optical 
record carrier against unauthorized reading and/or copying with a computer 
according to the present invention comprises the steps of 

determining whether a target optical record carrier or a non target 
optical record carrier is inserted into a drive of the computer, and 

in case a target optical record carrier is inserted into the drive of the 
computer 

- modifying read requests to the protected data areas so that no data 
is read or the read data is useless, and/ or 

modifying write commands in respect to the data within the 
protected data areas to a recordable record carrier or other storage so 
that the written data is useless. 

Therewith, according to the present invention a copy protection is provided that 
works on a different level in respect to the known copy protection schemes, 



30 



35 



HOEFER SCHMITZ WEBER & PARTNER 

Sony DADC Austria AG " SON030401PEP 04.04.2003 



since, according to the present invention, not the content to be protected or 
information relating thereto or to secure the access to the information is altered 
Therefore, this scheme allows full accessibility to existing playback devices other 
than computer drives. On the other hand, computers on which the method 
5 according to the present invention is provided cannot access and/or copy target 
optical record carriers, i.e. such optical record carriers that are copy protected 
according to the present invention, since the read requests and/or write 
commands are modified so that the . data in the protected areas, i.e. specially 
designated areas, e.g. an audio session of a CD, is read and/or written to be 
10 useless data. 

It is self-evident that according to the present invention a target optical record 
carrier is somehow distinguishable from a non-target optical record carrier and 
that the method according to the present invention has somehow to be 
15 implemented in the used computer. 

/ 

In the method according to the present invention, preferably the modifying of 
read requests and/or of write commands is performed only in case no 
authentication is available. 

20 

This scheme widens the concept of not allowing any computer reading and/or 
writing so that a user with authentication can fully access the protected content 
with a computer. Provisions might , also be given that such accessed content 
might not be accessible by a computer from a copy thereof* since the copy might 
25 be indicated to be not accessible by a computer. Also, it is possible to produce a 
copy to which a different authentication might provide access. In this way also 
the number of 'child levels' of an original might be defined, i.e. the number of 
levels that allow a copy. e.g. only an original and a direct copy thereof allow 
copying with a respective authentication. 



In a preferred embodiment of the present invention, the determining and 
modifying steps are performed by routines implemented into a drive control layer 
within the computer. 

This allows the implementation of the inventive method into a computer without 
having to reboot the computer, which would be annoying for a user, because the 
reboot usually Jakes a time. The drive control layer is generally a layer that 
controls the computer drive, e.g." ^SCSFlayer. " ~ 
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In this preferred embodiment, preferably the routines 

replace a dispatch routine and a completion routine, and 
have the functionality to perform the determining and modifying steps 
and to call the replaced dispatch and completion routines for their execution 
based on the original or modified read requests and/or write commands. 

These features allow that e.g. by default the behaviour of the operating system of 
the computer is not changed by the implementation of the present invention 
Further, also the basic functionality of this operating system in respect to the 
•replaced' routines might be used by calling them with modified parameters to 
avoid replacement thereof, which prevents the occurrence of unwanted system 
failures. 

Alternatively or additionally, in this embodiment, preferably the routines are 
implemented by a driver that gets installed by an executable that gets 
automatically started when a target optical record carrier is inserted into the 
drive. / 



This procedure allows the use of the computer driver technology after the driver 
is installed at least once. Therewith, the installed driver might be automatically 
loaded after each new start of the computer so that other target optical record 
carriers that do not comprise the executable are copy protected according to the 
method according to the present invention. Of course, it is possible to install the 
driver in any other way on the computer, e.g. through a different application 
when the user is executing this different application on the computer, while the 
user is accessing an internet server, or with the installation of the operating 
system of the computer. ■ 

Preferably, the driver 

gets automatically loaded after each start of the computer, and/or 

does not comprise an unload routine, and/or 

changes its name randomly, and/or 

comprises filetimes that are set randomly, and/or 

comprises code that is changed randomly, and/or 
- is installed multiple times, but is only one time active, and/or 

can be installed by installation programs spread all over the computer's 

system. 
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These features of the driver according to the present invention aim to make the 
driver resident and not easy to remove within the operating system computer so 
that after a first installation preferably no second installation is needed, but the 
copy protection scheme according to the present invention is permanently 
5 available on the particular computer. Therewith, also target optical record 
carriers are copy protected that do not bring the implementation of the copy 
protection according to the present invention with them, e.g. old target optical 
record carriers. These target optical record carriers just need to have the 
identification features that identify a target optical record carrier to be applicable 
to the copy protection according to the present invention. 



10 



Alternatively or additionally preferably the driver comprises a communication 
interface to allow an exchange of control data and/or authentication data. 

15 This communication interface might be used to indicate protected areas on a 
target optical record carrier, to communicate authentication data to the driver, 
and/or to establish a communication among different installed drivers according 
to the present invention to achieve that only one of them is active. The 
communication via the communication interface is preferably encrypted. 

20 

According to the present invention a target optical record carrier might be 
distinguished from a non target optical record carrier by evaluating 

a predetermined session of the optical record carrier in respect to special 
modifications, and/ or 

25 ~ at least one of the tables of contents of the optical record carrier in 

respect to special entries, and/ or 

a predetermined session of the optical record carrier in respect to special 
subcode modifications, and/or 

predetermined data stored on the optical record carrier in respect to a 
30 watermark. 



Therewith, according to the present invention a target optical record carrier 
might simply carry a special sign that classifies it as a target optical record 
carrier. However, also more sophisticated features might be used, e.g. every 

35 record carrier that comprises a copy protection of some kind might be classified 
as a target optical record carrier or record carriers that comprise a particular 

^ciai copy protection or that comprise an indication identifying a particular 

disc label, ... . Therewith, accorcHngtoThe present invention "predetermined 
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'cracked' copy protection schemes can be re-activated or predetermined optical 
record carriers that are identifiable by their content might be 'equipped' with a 
copy protection even after their delivery and selling. 

According to the present invention, preferably a protected data area is identified 
on basis of 

a sector type, and/or 

a range of sectors, and/ or 

sectors that are subject of specific read sequences. 

Therewith, according to the present invention a protected data area must not be 
static for a particular target optical record carrier, but can also be dynamic e g 
based on certain accessing characteristics, e.g. in case the access of a disc 
cloning program or a ripping program is detected. 

According to the present invention, preferably a protected da.ta area is defined by 
at least one predetermined area, and/ or 
data stored on the optical record carrier itself. 

» 

20 The predetermined data area might be fixed, e.g. always the audio session or 
predetermined range of sectors, or variable. A variable predetermined data area 
might be indicated to the driver through its communication interface. The driver 
can also derive a variable predetermined data area from the target optical record 
carrier, e.g. on basis of its table of contents or on basis of a list that is stored on 

25 the target optical record carrier. 

According to the present invention, preferably the modifying of read requests so 
that the read data is useless, and/or the modifying of write commands so that 
the written data is useless comprises 

to abort a corresponding IO Request and/or IO Command with an error, 
and/ or ' 

to complete the corresponding IO Request and/or IO Command, but 
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35 



without processing the actual request and/or command, and/or 
to modify the respective data so that it is useless. 



• - - - -The modification of data so that it is useless might include the replacement of 
data with arbitrary or predetermined values so that e.g. the play of a copied 
audio CD is disturbed or that a comment is given that no original is reproduced. 
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The computer program product according to the present invention comprises 
computer program means adapted to perform the method steps as set-out above 
when being executed on a computer, digital signal processor, or the like. 

The computer readable storage means according to the present invention 
comprises a computer program product according to the present invention.. 

The optical record carrier according to the present invention comprises an 
executable that gets automatically started when the optical record carrier is 
inserted into the drive and that 

performs the method steps as set-out above when being executed on a 
computer, digital signal processor, or the like, and/ or 

installs a driver that performs the method steps as set-out above when 
being executed on a computer, digital signal processor, or the like. 



i 



In other words, the optical record carrier comprises an executable that might 
directly and/or indirectly implement the method according to the present 
invention. 



As indicated above, according to the present invention, the optical record carrier 
is preferably a multi-session CD that comprises an audio session and a data 
session with the executable that preferably has an autostart functionality. 
However, the autostart functionality is not mandatory. 

All different aspects of the present invention as set-out above and further 
elucidated below might be combined in any way. The accompanying drawings, 
which are incorporated in and constitute a part of this specification, illustrate 
an exemplary embodiment of the invention and, together with a general 
description of the invention given above, and the detailed description of the 
embodiment given below, serve to explain the principles of the invention, 
wherein: 

Fig. 1 shows a simplified scheme of the processing of an IO request in a 
multi layered driver model according to the present invention, 

Fig. 2 shows a rough structure of a modified SCSI command used for the 
communication interface according to the present invention, 



4 



HOEFER SCHMITZ WEBER & PARTNER 

Sony DADC Austria AG 



shows a simplified scheme of the processing of an IO request in ■ 
multi layered driver model according to the prior art, and 
Fig. 4 shows a rough structure of a SCSI command according to the prior 

5 

According to the , ollowing _ mplMy embodiment of ae 
med a of specally marked discs (target m 

and/ ° r C ° Pyine " FOT «• «- of content on optica, media . g CD 

(ISO UDF...,, readable by operating systems (e.g Windows) is used (called data 

At least the following parts are included in the data session- 

15 " TT' m0d ' r,,!<i SO " Ware ia " l ° d EXE ^' the fonowing, 
This EXE is typically a startup menu. , ' allowing). 

■ Enabled autoplay. which star* the EXE after' , he optical media was 
inserted into the drive. 



20 When the EXE is .aunched. either after a medium was inserted ,au«op,ay, in the 
drive or by a user starting it manually, i, will e*ract and install a spell 
designed filter driver (called driver in the following, which performs the foiling 

* ******** between target discs, which are intended to be protected, 
and non target discs. 

■ Modifying specific SCSI read requests to the target disc* protected data 
areas m a way that makes the read data useless. 

Also write commands directed ,„ writing such data that relates to the target 
30 disc s protected data to a recordable disc or to another memory might Z 

the r T that makeS Wri " en ^ "— «•« relates ta 

u taTe V Pr ° ,eC,ed dSte m ' eht bC ' dentmed ^ * k or othe 

suitable mechanisms. 

35 fhetnerT" 0 T' " '^"'^ *° d applying fUter driver forces a reboot of 
op "^ . a particuta, and specific filtering method is used. " 
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Fig. 3 shows a simplified scheme how an IO request is processed in a multi 
layered driver model as e.g. used in Windows operating systems. Marked with (D 
is the call of the Dispatch Routine of every layer by an IO Manager, starting with 
layer 1. The last layer is accessing the physical device, which is marked with @. 
5 After the physical device is finished, the IO Manager calls the Completion 
Routine of every layer, starting with the last one, which is marked with ®. After 
the first layers completion routine has completed the IO Request is finished, 
which is marked with ®. 

10 According to the exemplary embodiment of the present invention, the driver 
searches for the SCSI layer and inserts its own routines DHR (Dispatch Hook 
Routine) and CHR (Completion Hook Routine) instead of the original Dispatch 
and Completion Routines, as it is indicated in Fig. 1. DHR as well as CHR call 
their original counterparts, i.e. the original dispatch routine and the original 

15 completion routine, so that by default the behaviour of the system 'is not changed 

through the injection of the hook routines. ' 

/* 

In particular, Fig. 1 elucidates how the driver is able to keep track of every SCSI 
command sent to a CD /DVD device by inserting the Dispatch and the completion 
20 Hook routines into the SCSI layer. Marked with © is that the Dispatch Routine of 
the SCSI layer is replaced with a Dispatch hook routine of the driver. This 
routine calls the original Dispatch Routine. Marked with © is that the 
Completion Routine of the SCSI layer is replaced with a Completion Hook 
Routine of the driver. This routine calls the original Completion Routine. 

25 

So that the driver is able to keep track of every SCSI request, which is sent to a 
CD/ DVD drive by using DHR and CHR, the following tasks are performed inside 
DHR and CHR: 

■ Distinguishing target discs from non target discs. 

30 • . Carry out modifications if a target disc was properly identified. 

■ Handling CCI requests (Covert Communication Interface) 

To distinguish between target and non target discs the following criteria are 
used in any .combination: 
35 ■ Special modifications in the 2 nd session. 

• Special TOC entries. 

Special subcode modifications (either in the 1st or the second session). 

■ Watermark in the (audio) data " 
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The protected data is part of the target disc. The following criteria might be used 
to identify protected data areas on a target disc: 

• Sector type, which means all sectors of a specified type (CDDA, Mode 1 , 
5 are part of the protected data area. 

■ Range of sectors, wherein a protected data area can be defined by 
specifying a start- and an endsector. 

- Detecting specific read sequences, e.g. sequential reads, which are typical 
for disc cloning and ripping programs, are detected and all further read 

10 requests are denied. 

The protected data area can be either protected: 

- Totally, which means that no read request to the protected area is allowed 
No matter, which application performs the request 

15 ■ Disengageable, which means that trusted applications can authenticate 
themselves by sending authentication data via the CCI (Covert 
Communication Interface,, which enables only the authenticated process 
to read the protected data. 



So one or multiple protected data areas can be specified with the ahov. criteria 
in any combination. 

The protected data areas can be defined by: 

the driver (hardcoded in the driver program code) 
■ data stored on the disc 
25 • combination of both 

If a target disc was properly identified, the following modifications might be done 
to SCSI read requests, which try to read protected data: 

The IO Request is aborted (completed) with an error. 

The IO Request is completed with STATUS.SUCCESS, without processing 
the actual read. e 

The read data is modified, so that it is useless. 

To protect the driver against removal from the system one or more of the 
following measures might be taken 

ThC driV6r ° an n0t be "^loaded, because it does not have an "Unload 
routine". 

The driver name changes randomly 
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o The installation process chooses a random name (done by EXE), 
o The driver changes its name during system runtime and/ or during 
system shutdown randomly. 

■ The driver filetimes (creation time, last access time and last write time) 

5 are set randomly during the installation sequence (done by EXE) and/ or 

during runtime. 

■ The driver program code is changed randomly (without changing its 
functionality) during the installation sequence, (done by EXE). 

The driver installs itself multiple times and except one all other instances 
10 of the driver are inactive. 

o There is a covert and protected communication interface between 
the drivers to check if there is already an active driver instance 
running. 

o If a driver detects another one already running, it will set itself 
15 inactive. 

• Spread driver installation programs (hidden) all over the system. 

In the following the Covert Communication Interface (CCI) according to the 
present invention is described, which is used for allowing software to 
20 communicate with the driver, e.g. for authentication, and/ or allowing drivers to 
communicate with each other, e.g. in case multiple instances of a driver are 
installed. 



SCSI commands are used to send and receive data to and from the driver (piggy 
25 back). Fig. 4 shows the rough structure of a SCSI command, which consists of a 
CDB, i.e. SCSI Command Descriptor Block, and, if the sent command requires it, 
a data buffer as well. Depending on the CDB the Data buffer could be used for 
storing read data (read command), or as data source if a write command is 
executed. The bufferlength can be a value >= 0 also depending on the CDB 

30 

According to the exemplary embodiment of the present invention, for 
communication purposes a larger datablock as required for the SCSI command is 
attached to the SCSI command to generate a modified SCSI command for use for 
the covert communication interface (CCI), as shown in Fig. 3. The data buffer 
35 area which is not needed for the SCSI command will in the following be named as 
DBE (Data buffer extension). 
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The DBE is used for CCI and contains information, which is detected and 
evaluated by the driver and the driver will place possible return values in the 
DBE as well. 

5 The content of the DBE is encrypted by the sender and decrypted by the driver. If 
the driver places return values in the DBE it will encrypt the DBE afterwards and 
the sender will decrypt the DBE again. 

All SCSI commands are applicable, i.e. commands, which do not need a data 
10 buffer themselves, are particulary suitable to be used for CCI (e.g. Test Unit 
Ready), because they are easy to handle. Self defined SCSI commands could be 
used as well. 



To easily install the driver, according to the exemplary embodiment of the 
15 present invention a driver installation sequence gets injected in an executable. 
This is used to add the code, which is extracting and installing the driver to any 
executable (called Target.exe in the following). Therefore, the. 'following tasks are 
performed: 

Create a dynamically loadable library file (e.g DLL for Windows operating 
20 systems). 

o Containing the driver. 

o Implements and forwards the interface of a dynamically loadable 
library (called target library) which is used by Target.exe. (e.g 
Kernel32.dll on Windows operating systems) 
25 o Contains a startup routine, which is called when the library is 

loaded. (DllMain routine in DLLs on Windows operating systems). 
This startup routine extracts and installs the driver, 
o The library can have any name, but the length of the name should 
not be longer then the name of the target library. To ease 
30 explaination it is called Inject.dll. 

An executable contains a list of all dynamically loadable libraries (called 
import list), which are used. 
■ When an executable is started every library listed in the import list is 
loaded and its star tuprou tine is executed. 
35 • The name of the target library (e.g Kernel32.dll) in the import list of 
Target.exeisrepiacedwiththenameofInject.dll. ----- 
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So when Target.exe is executed Inject.dll is loaded as well and its startuproutine 
is executed, which extracts and installs the driver. 
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Claims 

1 . Method to protect content within protected data areas on a target optical 
record carrier against unauthorized reading and/or copying with a computer, 
characterized by the steps of 

determining whether a target optical record carrier or a non-target 
optical record carrier is inserted into a drive of the computer, and 

in case a target optical record carrier is inserted into the drive of the 
computer 

modifying read requests to the protected data areas so that no data 
is read or the read data is useless, and /or 

modifying write commands in respect to the data within the 
protected data areas to a recordable record carrie^ or other storage so 
that the written data is useless. , 
15 f 

2. Method according to claim 1, characterized in that the modifying of read 
requests and/ or of .write commands is performed only in case no authentication 
is available. 

20 3, Method according to claim 1 or 2, characterized in that the determining 

and modifying steps are performed by routines implemented into a drive control 
layer within the computer. 

4. Method according to claim 3, characterized in that the routines 

25 - replace a dispatch routine and a completion routine, and 

have the functionality to perform the determining and modifying steps 
and to call the replaced dispatch and completion routines for their execution 
based on the original or modified read requests and/or write commands. 

30 5. Method according to claim 3 or 4, characterized in that the routines are 

implemented by a driver that gets installed by an executable that gets 
automatically started when a target optical record carrier is inserted into the 
drive. 



35 6. Method according to claim 5, characterized in that the driver 

- - - gets automatically loaded after each start of the computer, and/or 

does not comprise an unload routine, and/ or 
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changes its name randomly, and for 

comprises filetimes that are set randomly, and/ or 

comprises code that is changed randomly, and/or 

is installed multiple times, but is only one time active, and/ or 

can be installed by installation programs spread all over the computer's 

system. 

7. Method according to claim 5 or 6, characterized in that the driver 
comprises a communication interface to allow an exchange of control data 
and /or authentication data. 

8. Method according to anyone of the preceding claims, characterized in 
that a target optical record carrier is distinguished from a- non target optical 
record carrier by evaluating ' 

a predetermined session of the optical record carrier in respect to special 

modifications, and/ or 

at least one of the tables of contents of the optical record carrier in 

respect to special entries, and/ or 

a predetermined session of the optical record carrier in respect to special 
subcode modifications, and /or 

predetermined data stored on the optical record carrier in respect to a 

watermark. 

9. Method according to anyone of the preceding claims, characterized in 
that a protected data area is identified on basis of 

a sector type, and/ or 

a range of sectors, and /or 

sectors that are subject of specific read sequences. 

10. Method according to anyone of the preceding claims, characterized in 
that a protected data area is defined by 

at least one predetermined area, and/ or 
data stored on the optical record carrier itself. 

11. Method according to anyone of the preceding claims, characterized in 
that the modifying of read requests so that the read data is useless, and/or the 
modifying of write commands so that the written data is useless comprises 
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to abort a corresponding IO Request and/or IO Command with an error, 

and /or 

to complete the corresponding IO Request and /or IO Command, but 
without processing the actual request and/ or command, and/ or 
to modify the respective data so that it is useless. 

12. Computer program product, comprising computer program means 
adapted to perform the method steps as defined in anyone of claims 1 to 1 1 when 
being executed on a computer, digital signal processor, or the like. 

13. Computer readable storage means, comprising a computer program 
product according to claim 12. 



14. Optical record carrier, characterised by an executable that gets 
15 automatically started when the optical record carrier is inserted into the drive; 
and that . . 

performs the method steps as defined in anyone of claims 1 to 1 1 when 
being executed on a computer, digital signal processor, or the like, and/or 

installs a driver that performs the method steps as defined in anyone of 
20 claims 1 to 11 when being executed on a computer, digital signal processor, or 
the like. 
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15. Optical record carrier according to claim 14, characterized in that the 
executable is arranged in a data session of a multi-session CD that also 
comprises an audio session. 
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Abstract 

Optical Media Protection Driver 

A method to protect content within protected data areas on a target optical 
record carrier against unauthorized reading and/ or copying with a computer, 
comprises the steps of 

determining whether a target optical record carrier or a non-target 
optical record carrier is inserted into a drive of the computer, and 

in case a target optical record carrier is inserted into the drive of the 
computer 

modifying read requests to the protected data areas so that no data 
is read or the read data is useless, and/ or 

modifying write commands in respect to the data within the 
protected data areas to a recordable record carrier or other storage so 
that the written data is useless. 
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.The Dispatch Routine of the SCSI layer 
is replaced with a Dispatch hook routine 
of the driver. This routine calls the 
original Dispatch Routine. 

.The Completion Routine of the SCSI 
layer is replaced with a Completion 
Hook Routine of the driver. This routine 
calls the original Completion Routine. 
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CDB SCSI Command Descriptor Block 

Data buffer Depending on the CDB the 

buffertength can be a value >= 0 
Data buffer ext Extension to the data buffer used 

forCCl. 



Fig. 2 




CDB SCSI Command Descriptor Block 

Data buffer Depending on the CDB the 

buffertength can be a value >= 0 
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1 IO Manager calls the Dispatch Routine 
of every layer, starting with layer 1 . 

2 The last layer is accessing the physical 

device. 

3 After the physical device is finished, the 

IO Manager calls the Completion 
Routine of every layer, starting with the 
last one. 

4 After the 1 st layers completion routine 

has completed the IO Request is 
finished. 
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